AMENDMENT 

In the Claims 

Please amend claims 1 , 3, 4, 6, 8, 9, 11 , 1 3, 1 5, 17-21, 23, 25, 27-31 , 33-35, 37, 
38, and 41 as follows. 

1 . (Currently Amended) A method comprising: 

starting execution of a basic input output system (BIOS), the BIOS having a 
plurality of firmware modules; 

determining resources required by the plurality of firmware modules to operate ; 

scheduling e x e cut i on of modules of the plurality of firmware modules for 
execution in consideration of the required resource that are determined ; and 

dispatching the scheduled modules for execution. 

2. (Original) The method of claim 1, further comprising initializing a memory of the 
platform after the scheduled modules are dispatched. 

3. (Currently Amended) The method of claim 1, further comprising calling a module 
of the plurality of firmware modules for execution during execution of another module of 
the plurality of firmware modules. 

4. (Currently Amended) The method of claim 3, wherein calling a module of the 
plurality of firmware modules further comprises: 

saving a return address; 

determining a physical address of the module; 

executing an instruction stored at the physical address of the module; and 
executing an instruction stored at the saved return address when the module 
execution is complete. 
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5. (Original) The method of claim 4, wherein determining the physical address of 
the module comprises looking up the physical address in an import table of the other 
module. 

6. (Currently Amended) The method of claim 1, wherein a module of the plurality of 
firmware modules comprises: 

a globally unique identifier (GUID) to identify the module; 

a resource list to store information identifying resources needed by the module to 
operate; 

an import table to store physical addresses of a set of modules of the plurality of 
firmware modules that the module may call during execution; 

a service that when executed performs a predetermined function; 

an export table to store a value corresponding to a physical address of the 
service; and 

an interface operatively coupled to the GUID, resource list, the service, the 
import table, and the export table, wherein the interface is addressable by a calling 
agent via the GUID to provide the calling agent access to the resource list, the service, 
the import table, and the export table. 

7. (Original) The method of claim 6, wherein the value stored by the export table is 
an offset from a start address of the module. 

8. (Currently Amended) The method of claim 6, wherein the import table to stor e 
stores GUIDs of the set of modules of the plurality of firmware modules. 

9. (Currently Amended) The method of claim 1 , further comprising: 
starting execution of a first module of the plurality of firmware modules; 
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determining whether the first module is chainable with another module of the 
plurality of firmware modules; 

determining whether a hardware component associated with the first module is 
present in the platform if the first module is chainable; 

completing execution of the first module if the hardware component associated 
with the first module is present in the platform; and 

starting execution of a second module of the plurality of firmware modules 
without completing execution of the first module if the hardware component associated 
with the first module is not present in the platform. 

10. (Original) The method of claim 9, wherein the first module includes a data 
structure to store a physical address of the second module. 

1 1 . (Currently Amended) The method of claim 9, further comprising: 

determining whether a hardware component associated with the second module 
of the plurality of firmware modules is present in the platform if the first module is 
chainable; 

completing execution of the second module if the hardware component 
associated with the second module is present in the platform; 

determining whether a third module is chained to the second module if the 
hardware component associated with the second module is not present in the platform; 
and 

executing the third module of the plurality of firmware modules without 
completing execution of the second module if third module is chained to the second 
module. 
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12. (Original) The method of claim 11, wherein completing execution of the second 
module further comprises returning to a calling agent that called the first module. 

1 3. (Currently Amended) The method of claim 1 , further comprising: 

executing a call made by a calling agent to a first module of the plurality of 
firmware modules, wherein the call is one of a set of calls, each call of the set of calls 
being associated with a module of a set of modules of the plurality of firmware modules, 
the associations being dependent on a configuration of the platform; 

starting execution of the first module of the plurality of firmware modules in 
response to the call; 

determining which module of the set of modules is associated with the call; and 
starting execution of the module associated with the call. 

14. (Original) The method of claim 13, further comprising returning to the calling 
agent when execution of the module associated with the call is complete. 

15. (Currently Amended) A machine readable medium containing instructions that 
when executed by a machine, cause the machine to perform operations comprising: 

starting execution of a BIOS, the BIOS having a plurality of firmware modules; 
determining resources required by the plurality of firmware modules to operate ; 
scheduling oxocution of modules of the plurality of firmware modules for 
execution in consideration of the required resource that are determined ; and 
dispatching the scheduled modules for execution. 

16. (Original) The machine readable medium of claim 15, further comprising 
instructions that when executed by the machine cause the machine to perform an 
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operation of initializing a memory of the machine after the scheduled modules are 
dispatched. 

17. (Currently Amended) The machine readable medium of claim 15, further 
comprising instructions that when executed by the machine cause the machine to 
perform an operation of calling a module of the plurality of firmware modules for 
execution during execution of another module of the plurality of firmware modules. 

18. (Currently Amended) The machine readable medium of claim 17, wherein calling 
a module of the plurality of firmware modules further comprises instructions that when 
executed by the machine cause the machine to perform operations comprising: 

saving a return address; 

determining a physical address of the module; 

executing an instruction stored at the physical address of the module; and 
executing an instruction stored at the saved return address when the module 
execution is complete. 

19. (Currently Amended) The machine readable medium of claim 15, wherein a 
module of the plurality of firmware modules comprises: 

a globally unique identifier (GUID) to identify the module; 

a resource list to store information identifying resources needed by the module to 
operate; 

an import table to store physical addresses of a set of modules of the plurality of 
firmware modules that the module may call during execution; 

a service that when executed performs a predetermined function; 

an export table to store a value corresponding to a physical address of the 
service; and 
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an interface operatively coupled to the GUID, resource list, the service, the 
import table, and the export table, wherein the interface is addressable by a calling 
agent via the GUID to provide the calling agent access to the resource list, the service, 
the import table, and the export table. 

20. (Currently Amended) The machine readable medium of claim 15, further 
comprising instructions that when executed by the machine cause the machine to 
perform operations comprising 

starting execution of a first module of the plurality of firmware modules; 

determining whether the first module is a chainable with another module of the 
plurality of firmware modules; 

determining whether a hardware component associated with the first module is 
present in the machine if the first module is chainable; 

completing execution of the first module if the hardware component associated 
with the first module is present in the machine; and 

starting execution of a second module of the plurality of firmware modules 
without completing execution of the first module if the hardware component associated 
with the first module is not present in the machine. 

21. (Currently Amended) The machine readable medium of claim 20, further 
comprising instructions that when executed by the machine cause the machine to 
perform operations comprising: 

determining whether a hardware component associated with the second module 
of the plurality of firmware modules is present in the machine if the first module is 
chainable; 

completing execution of the second module if the hardware component 
associated with the second module is present in the machine; 
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determining whether a third module is chained to the second module if the 
hardware component associated with the second module is not present in the machine; 
and 

executing the third module of the plurality of firmware modules without 
completing execution of the second module if third module is chained to the second 
module. 

22. (Original) The machine readable medium of claim 21, wherein completing 
execution of the second module further comprising instructions that when executed by 
the machine cause the machine to perform an operation of returning to a calling agent 
that called the first module. 

23. (Currently Amended) The machine readable medium of claim 15, further 
comprising instructions that when executed by the machine cause the machine to 
perform operations comprising: 

executing a call made by a calling agent to a first module of the plurality of 
firmware modules, wherein the call is one of a set of calls, each call of the set of calls 
being associated with a module of a set of modules of the plurality of firmware modules, 
the associations being dependent on a configuration of the machine; 

starting execution of the first module of the plurality of firmware modules in 
response to the call; 

determining which module of the set of modules is associated with the call; and 
starting execution of the module associated with the call. 

24. (Original) The machine readable medium of claim 23, further comprising 
instructions that when executed by the machine cause the machine to perform an 
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operation of returning to the calling agent when execution of the module associated with 
the call is complete. 

25. (Currently Amended) A system, comprising: 
a plurality of hardware components[[;]]: 

a first memory device to store a BIOS, the BIOS having a plurality of firmware 
modules, the BIOS further including; 

means for determining resources required by the plurality of firmware 
modules to operate , 

means for scheduling execution of modules of the plurality of firmware 

modules, and 

means for dispatching scheduled modules for execution; and 
a processor coupled to the plurality of hardware components and the first 
memory device. 

26. (Original) The system of claim 25, wherein the BIOS further comprises means for 
initializing a memory of the system after the scheduled modules are dispatched. 

27. (Currently Amended) The system of claim 25, wherein the BIOS further 
comprises means for calling a module of the plurality of firmware modules for execution 
during execution of another module of the plurality of firmware modules. 

28. (Currently Amended) The system of claim 27, wherein the means for calling a 
module of the plurality of firmware modules further comprises: 

means for saving a return address; 

means for determining a physical address of the module; 
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means for executing an instruction stored at the physical address of the module; 

and 

means for executing an instruction stored at the saved return address when the 
module execution is complete. 

29. (Currently Amended) The system of claim 25, wherein a module of the plurality of 
firmware modules comprises: 

a globally unique identifier (GUID) to identify the module; 

a resource list to store information identifying resources needed by the module to 
operate; 

an import table to store physical addresses of a set of modules of the plurality of 
firmware modules that the module may call during execution; 

a service that when executed performs a predetermined function; 

an export table to store a value corresponding to a physical address of the 
service; and 

an interface operatively coupled to the GUID, resource list, the service, the 
import table, and the export table, wherein the interface is addressable by a calling 
agent via the GUID to provide the calling agent access to the resource list, the service, 
the import table, and the export table. 

30. (Currently Amended) The system of claim 25, wherein the BIOS further 
comprises: 

means for starting execution of a first module of the plurality of firmware 
modules; 

means for determining whether the first module is a chainable with another 
module of the plurality of firmware modules; 
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means for determining whether a hardware component of the plurality of 
hardware components that is associated with the first module is present in the system if 
the first module is chainable; 

means for completing execution of the first module if the hardware component 
associated with the first module is present in the system; and 

means for starting execution of a second module of the plurality of firmware 
modules without completing execution of the first module if the hardware component 
associated with the first module is not present in the system. 

31. (Currently Amended) The system of claim 30, wherein the BIOS further 
comprises: 

means for determining whether a hardware component associated with the 
second module of the plurality of firmware modules is present in the system if the first 
module is chainable; 

means for completing execution of the second module if the hardware 
component associated with the second module is present in the system; 

means for determining whether a third module is chained to the second module if 
the hardware component associated with the second module is not present in the 
system; and 

means for executing the third module of the plurality of firmware modules without 
completing execution of the second module if third module is chained to the second 
module. 

32. (Original) The system of claim 31 , wherein the means for completing execution of 
the second module further comprises means for returning to a calling agent that called 
the first module. 
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33. (Currently Amended) The system of claim 28, wherein the BIOS further 
comprises: 

means for executing a call made by a calling agent to a first module of the 
plurality of firmware modules, wherein the call is one of a set of calls, each call of the 
set of calls being associated with a module of a set of modules of the plurality of 
firmware modules, the associations being dependent on a configuration of the system; 

means for starting execution of the first module of the plurality of firmware 
modules in response to the call; 

means for determining which module of the set of modules is associated with the 
call; and 

means for starting execution of the module associated with the call. 

34. (Currently Amended) A system, comprising: 
a plurality of hardware components; 

a first memory device to store a BIOS, the BIOS comprising: 

a plurality of firmware modules, each module of the plurality of firmware 
modules to provide at least one service , at least two modules providing an inter- 
module interface to enable each of said at least two modules to call a service 
provided by another module : 

a core operatively coupled to the plurality of firmware modules, wherein 
the core, upon operation, to s ele ct selects for execution a set of modul e modules 
from the plurality of firmware modules; 

a processor coupled to the plurality of hardware components and the first 
memory device. 
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35. (Currently Amended) The system of claim 34, wherein during execution of a first 
module of the plurality of firmware modules, the first module to selectively call a second 
module of the plurality of firmware modules for execution. 

36. (Original) The system of claim 35, wherein the first module comprises an import 
table to store a physical address of the second module, the first module further to store 
a return address in a register of the processor in calling the second module. 

37. (Currently Amended) The system of claim 34, wherein a module of the plurality of 
firmware modules comprises: 

a globally unique identifier (GUID) to identify the module; 
a resource list to store information identifying resources needed by the module to 
operate; 

an import table to store physical addresses of a set of modules of the plurality of 
firmware modules that the module may call during execution; 

a service that when executed performs a predetermined function; 

an export table to store a value corresponding to a physical address of the 
service; and 

an interface operatively coupled to the GUID, resource list, the service, the 
import table, and the export table, wherein the interface is addressable by a calling 
agent via the GUID to provide the calling agent access to the resource list, the service, 
the import table, and the export table. 

38. (Currently Amended) The system of claim 34, wherein a set of modules of the 
plurality of firmware modules have identical global unique identifiers (GUIDs). 



42P9143 

Ser. No. 10/073,495 



13 



Examiner: Chen, Tse W. 

Art Unit: 2116 



39. (Original) The system of claim 38, wherein during execution of a first module of 
the set of modules, the processor to complete execution of the first module when a first 
hardware component is associated with the first module is present in the system, the 
first hardware component being one of the plurality of hardware components. 

40. (Original) The system of claim 39, wherein the first module to call a second 
module of the set of modules when the first hardware component is not present in the 
system. 

41. (Currently Amended) The system of claim 34, wherein during execution of a first 
module of the plurality of firmware modules, the first module to call a second module of 
the plurality of firmware modules to perform a service, the second module to call a third 
module as a function of a configuration of the system, the third module being one of a 
set of modules of the plurality of firmware modules each being associated with a 
different hardware component of the plurality of hardware components that provide the 
service called by the first module. 
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